+Mon Aug 23 01:17:59 2004 Matthias Clasen <maclas@gmx.de>
+
+ * gdk/gdkrgb.c (gdk_rgb_xpixel_from_rgb_internal): Set unused
+ bits in pixel to 1s in case they are used as alpha; copying
+ code from gdk_colormap_alloc_colors(). (#150466, Rich Wareham)
+
2004-08-22 Philip Langdale <plangdale@vmware.com>
* gtk/gtkaction.c (gtk_action_disconnect_proxy): Two signals
+Mon Aug 23 01:17:59 2004 Matthias Clasen <maclas@gmx.de>
+
+ * gdk/gdkrgb.c (gdk_rgb_xpixel_from_rgb_internal): Set unused
+ bits in pixel to 1s in case they are used as alpha; copying
+ code from gdk_colormap_alloc_colors(). (#150466, Rich Wareham)
+
2004-08-22 Philip Langdale <plangdale@vmware.com>
* gtk/gtkaction.c (gtk_action_disconnect_proxy): Two signals
+Mon Aug 23 01:17:59 2004 Matthias Clasen <maclas@gmx.de>
+
+ * gdk/gdkrgb.c (gdk_rgb_xpixel_from_rgb_internal): Set unused
+ bits in pixel to 1s in case they are used as alpha; copying
+ code from gdk_colormap_alloc_colors(). (#150466, Rich Wareham)
+
2004-08-22 Philip Langdale <plangdale@vmware.com>
* gtk/gtkaction.c (gtk_action_disconnect_proxy): Two signals
+Mon Aug 23 01:17:59 2004 Matthias Clasen <maclas@gmx.de>
+
+ * gdk/gdkrgb.c (gdk_rgb_xpixel_from_rgb_internal): Set unused
+ bits in pixel to 1s in case they are used as alpha; copying
+ code from gdk_colormap_alloc_colors(). (#150466, Rich Wareham)
+
2004-08-22 Philip Langdale <plangdale@vmware.com>
* gtk/gtkaction.c (gtk_action_disconnect_proxy): Two signals
else if (image_info->visual->type == GDK_VISUAL_TRUE_COLOR ||
image_info->visual->type == GDK_VISUAL_DIRECT_COLOR)
{
+ guint32 unused;
+
#ifdef VERBOSE
g_print ("shift, prec: r %d %d g %d %d b %d %d\n",
image_info->visual->red_shift,
image_info->visual->blue_shift,
image_info->visual->blue_prec);
#endif
+ /* If bits not used for color are used for something other than padding,
+ * it's likely alpha, so we set them to 1s.
+ */
+ unused = ~ (image_info->visual->red_mask |
+ image_info->visual->green_mask |
+ image_info->visual->blue_mask |
+ (((~(guint32)0)) << image_info->visual->depth));
- pixel = (((r >> (16 - image_info->visual->red_prec)) << image_info->visual->red_shift) +
+ pixel = (unused + ((r >> (16 - image_info->visual->red_prec)) << image_info->visual->red_shift) +
((g >> (16 - image_info->visual->green_prec)) << image_info->visual->green_shift) +
((b >> (16 - image_info->visual->blue_prec)) << image_info->visual->blue_shift));
}